Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Prebid plugin render changes #1068

Merged
merged 18 commits into from
Jan 6, 2025
Merged

Conversation

OlenaPostindustria
Copy link
Collaborator

@OlenaPostindustria OlenaPostindustria force-pushed the prebid-plugin-render-changes branch from 3dd14b6 to d3b3e83 Compare December 5, 2024 08:59
@OlenaPostindustria OlenaPostindustria marked this pull request as ready for review December 5, 2024 09:14
Copy link

@jangirtony2009 jangirtony2009 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@OlenaPostindustria Please take a look into the comments

import UIKit

@objcMembers
public class InterstitialController:

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@OlenaTeqBlaze this class needs to be open so that other renderers can create the child class and return it in PrebidMobileInterstitialPluginRenderer

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This class is the SDK internal one. Could you please clarify the reason for needing to create the child classes? The current implementation of the plugin renderer indicates that you need to create your own class and conform it to PrebidMobilePluginRenderer protocol. You can use SampleRenderer as reference.

Comment on lines 70 to 83
guard transactionFactory == nil else {
return
}

adConfiguration.adConfiguration.winningBidAdFormat = bid.adFormat
videoControlsConfig.initialize(with: bid.videoAdConfiguration)

// This part is dedicating to test server-side ad configurations.
// Need to be removed when ext.prebid.passthrough will be available.
#if DEBUG
adConfiguration.adConfiguration.videoControlsConfig.initialize(with: bid.testVideoAdConfiguration)
#endif

transactionFactory = PBMTransactionFactory(

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If I inherit from InterstitialController, I need to override the loadAd method to receive the callback required for my renderer to load an ad. However, I cannot call super.loadAd because that would initiate the creation of the transactionFactory and start loading the prebid render ad. If i don't call it then bid.adFormat will not able to set.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please, take a look at the comment above

@YuriyVelichkoPI
Copy link
Contributor

YuriyVelichkoPI commented Dec 6, 2024

@OlenaPostindustria Please take a look into the comments

Hi @jangirtony2009 ! Thanks for the review! We'll address your notes soon.

Please ignore the removed question if you saw it :)

@OlenaPostindustria OlenaPostindustria force-pushed the prebid-plugin-render-changes branch from f5f4fc1 to e868f09 Compare December 10, 2024 13:29
@OlenaPostindustria
Copy link
Collaborator Author

Hi, @jangirtony2009! Thank you for taking the time to review this pull request!
Could you please take a look at the updates when you get a chance?

@OlenaPostindustria OlenaPostindustria force-pushed the prebid-plugin-render-changes branch 2 times, most recently from 7c7ba8e to 3f2d806 Compare December 10, 2024 14:05

PBMLogWarn(@"SDK couldn't retrieve an implementation of PrebidMobileDisplayViewManagerProtocol. SDK will use the default one.");

PrebidRenderer *defaultRenderer = [PrebidRenderer new];

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why are you creating the new object only for PrebidRenderer? Why not for the customRenderer?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The third-party renderer has the option to return nil when creating a banner or interstitial. In such cases, we must fall back to the default renderer, even if the "custom" renderer was originally selected.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Since Prebid will maintain the same object, developers won’t be able to manage local variables within the class. Therefore, it’s better to make the createBanner and createInterstitial methods static. This will provide more clarity to developers.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi @jangirtony2009 ! We'll make a small change in order not to create a separate instance of PrebidRenderer.

However, it doesn't look meaningful to make methods like createBanner static. The reason is that third-party renderers will still be passed to the SDK as objects.

Please review the following changes and let us know if they add clarity to the solution and workflow design.

}

return preferredPlugin
}

public func getAllPlugins() -> [PrebidMobilePluginRenderer] {

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In prebid-android sdk is adding the default renderer in the adRequest and sending it to the server.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm not certain if we should do that, perhaps @YuriyVelichkoPI can help here.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, we should register the default renderer in the list. It will be a good design approach. However, I'm not sure if SDK sends any signals indicating the presence of a default renderer. We'll double-check it.

Copy link
Contributor

@YuriyVelichkoPI YuriyVelichkoPI Dec 17, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@jangirtony2009, we checked the Android behavior and @ValentinPostindustria says that the SDK doesn't send any info about the default rendered in the request. So could you clarify this part of your comment

... and sending it to the server

Thanks!

@OlenaPostindustria OlenaPostindustria force-pushed the prebid-plugin-render-changes branch 2 times, most recently from 02736b0 to 4b4e8d4 Compare December 19, 2024 08:23
Copy link
Contributor

@YuriyVelichkoPI YuriyVelichkoPI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@YuriyVelichkoPI YuriyVelichkoPI merged commit 46e330f into master Jan 6, 2025
4 checks passed
@YuriyVelichkoPI YuriyVelichkoPI deleted the prebid-plugin-render-changes branch January 6, 2025 08:08
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants